分治法:将原问题划分为n个规模较小而结构与原问题相似的子问题;递归地解决这些子问题,然后再合并其结果,就得到了原问题的解。分治法在每一个递归上都有三个步骤:分解、解决、合并。而在本文中的合并排序法正是运用了这种分而治之的策略:把一个n个元素的数组先分成两个数组,然后继续分下去,知道分成n个数组;然后将其逐一合并排序,最终得到排列好了的数组。下面我们首先看一看合并排序了原理框图:(图中黑色部分看不见不要紧,只需了解是将数组L、R中浅颜色的元素从小到大依次填入数组A中)
上述原理的具体代码实现如下:
1 | /*************************************** |
下面演示了合并排序在对一个数组的处理过程:
上图中的合并排序过程的总的测试程序如下:
1 |
|
注意:我是在vs2008上运行的,与vc 6.0有点区别,主要是循环体中的循环变量的作用域,出错体现在循环变量的重复定义上。例如:在vs2008或vs2010上,程序为:
#include
void main()
{
int i=0;
for(int i=0;i<5;i++)
printf(“%d “,i);
}
则在VC 6.0上需改为:
#include
void main()
{
int i=0;
for(i=0;i<5;i++)
printf(“%d “,i);
}